;;! target = "riscv64"
;;!
;;! settings = ['enable_heap_access_spectre_mitigation=true']
;;!
;;! compile = true
;;!
;;! [globals.vmctx]
;;! type = "i64"
;;! vmctx = true
;;!
;;! [globals.heap_base]
;;! type = "i64"
;;! load = { base = "vmctx", offset = 0, readonly = true }
;;!
;;! [globals.heap_bound]
;;! type = "i64"
;;! load = { base = "vmctx", offset = 8, readonly = true }
;;!
;;! [[heaps]]
;;! base = "heap_base"
;;! min_size = 0x10000
;;! offset_guard_size = 0xffffffff
;;! index_type = "i64"
;;! style = { kind = "dynamic", bound = "heap_bound" }

;; !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
;; !!! GENERATED BY 'make-load-store-tests.sh' DO NOT EDIT !!!
;; !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

(module
  (memory i64 1)

  (func (export "do_store") (param i64 i32)
    local.get 0
    local.get 1
    i32.store8 offset=0x1000)

  (func (export "do_load") (param i64) (result i32)
    local.get 0
    i32.load8_u offset=0x1000))

;; function u0:0:
;; block0:
;;   ld t1,8(a2)
;;   lui t0,1048575
;;   addi t0,t0,4095
;;   add a3,t1,t0
;;   ld t1,0(a2)
;;   add t1,t1,a0
;;   lui t0,1
;;   add t2,t1,t0
;;   ugt t0,a0,a3##ty=i64
;;   li a0,0
;;   selectif_spectre_guard t1,a0,t2##test=t0
;;   sb a1,0(t1)
;;   j label1
;; block1:
;;   ret
;;
;; function u0:1:
;; block0:
;;   ld t1,8(a1)
;;   lui t0,1048575
;;   addi t0,t0,4095
;;   add a2,t1,t0
;;   ld t1,0(a1)
;;   add t1,t1,a0
;;   lui t0,1
;;   add t2,t1,t0
;;   ugt t0,a0,a2##ty=i64
;;   li a0,0
;;   selectif_spectre_guard t1,a0,t2##test=t0
;;   lbu a0,0(t1)
;;   j label1
;; block1:
;;   ret